'use strict'

/*
1、题目描述
找出元素 item 在给定数组 arr 中的位置
输出描述:
如果数组中存在 item，则返回元素在数组中的位置，否则返回 -1
示例1
输入
[ 1, 2, 3, 4 ], 3
输出
2
*/
function indexOf(arr, item) {
    if (arr.indexOf(item) > 0) {
        return arr.indexOf(item);
    } else {
        return -1;
    };
}
var arr = [1, 2, 3, 4]
console.log(indexOf(arr, 3));

/*
2、题目描述
计算给定数组 arr 中所有元素的总和
输入描述:
数组中的元素均为 Number 类型
示例1
输入

[ 1, 2, 3, 4 ]
输出

10

*/
function sum(array) {
    var sum = 0;
    arr.forEach(function (item, index) {
        sum = sum + item;
    })
    return sum;
}
var array = [1, 2, 3, 4]
console.log(sum(arr));

/*
3、题目描述
移除数组 arr 中的所有值与 item 相等的元素。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4, 2], 2
输出

[1, 3, 4]
*/
var arr = [1, 2, 3, 4, 2]
function remove(arr, item) {
    var reault = [];
    arr.foreach(function (arrItem) {
        if (item != arrItem) {
            result.push(arrItem);
        }
    })
    return reault;
}
console.log(remove(arr, 2));

/*
4、题目描述
移除数组 arr 中的所有值与 item 相等的元素，直接在给定的 arr 数组上进行操作，并将结果返回
示例1
输入

[1, 2, 2, 3, 4, 2, 2], 2
输出

[1, 3, 4]
*/
function remove(arr, item) {
    var a = arr.slice(0);
    for (var i = 0; i < arr.length; i++) {
        if (a[i] === item) {
            a.splice(i, 1);
            i--;
        }
    }
    return a;
};
console.log(remove(arr, 2));

/*
5、题目描述
在数组 arr 末尾添加元素 item。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4],  10
输出

[1, 2, 3, 4, 10]
*/
function append(arr, item) {
    var result = [];
    arr.forEach(function (arrItem) {
        result.push(arrItem);
    })
    result.push(item);
    return result;
}
var arr = [1, 2, 3, 4]
console.log(append(arr, 10));


/*
6、题目描述
删除数组 arr 最后一个元素。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4]
输出

[1, 2, 3]

*/
var arr = [1, 2, 3, 4]
function truncate(arr) {
    var arr1 = arr.slice(0);
    arr1.pop(arr1.length - 1);
    return arr1;
}
console.log(truncate(arr));


/*
7、题目描述
在数组 arr 开头添加元素 item。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4], 10
输出

[10, 1, 2, 3, 4]

function prepend(arr, item) {

}
*/
function prepend(arr, item) {
    var arr1 = arr.slice(0);
    arr1[arr1.length] = item;
    return arr1;
}
var arr = [1, 2, 3, 4]
console.log(prepend(arr, 10));

/*
8、题目描述
删除数组 arr 第一个元素。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4]
输出

[2, 3, 4]

function curtail(arr) {

}
*/
var arr = [1, 2, 3, 4]
function curtail(arr) {
    var result = arr.slice(0);
    result.shift();
    return result;
}
console.log(curtail(arr));


/*
9、题目描述
合并数组 arr1 和数组 arr2。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4], ['a', 'b', 'c', 1]
输出

[1, 2, 3, 4, 'a', 'b', 'c', 1]

function concat(arr1, arr2) {

}
*/
function concat(arr1, arr2) {
    var arr1 = [1, 2, 3, 4];
    var arr2 = ['a', 'b', 'c', 1];
    function concat(arr1, arr2) {
        var currentArr1 = arr1.slice(0);
        var currentArr2 = arr2.slice(0);
        return currentArr1.concat(currentArr2)
    }
    console.log(concat(arr1, arr2));
}
/*
10、题目描述
在数组 arr 的 index 处添加元素 item。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4], 'z', 2
输出

[1, 2, 'z', 3, 4]
*/
function index(arr, item, index) {
    var newArr = arr.slice(0);
    newArr.splice(index, 0, item);
    return newArr;
}
console.log(index(arr, 'z', 2))

/*
11、题目描述
统计数组 arr 中值等于 item 的元素出现的次数
示例1
输入

[1, 2, 4, 4, 3, 4, 3], 4
输出

3
*/
var arr = [1, 2, 4, 4, 3, 4, 3];
var item = 4;
var count = 0;
for (var i = 0; i < arr.length; i++) {
    if (arr[i] == item) {
        count++
    }
}
console.log(count)

/*
12、题目描述
找出数组 arr 中重复出现过的元素
示例1
输入

[1, 2, 4, 4, 3, 3, 1, 5, 3]
输出

[1, 3, 4]
*/
function duplicates(arr) {
    for (var i = 0; i < arr.length; i++) {
        if (arr[i] === item) {
            return arr[i];
        }
    }
    var arr = [1, 2, 4, 4, 3, 3, 1, 5, 3]
}
console.log(duplicates(arr));

/*
13、题目描述
为数组 arr 中的每个元素求二次方。不要直接修改数组 arr，结果返回新的数组
示例1
输入

[1, 2, 3, 4]
输出

[1, 4, 9, 16]
*/
function square(arr) {

}

/*
14、题目描述
在数组 arr 中，查找值与 item 相等的元素出现的所有位置
示例1
输入

['a','b','c','d','e','f','a','b','c'] 'a'
输出

[0, 6]

function findAllOccurrences(arr, target) {

}
*/
function findAllOccurrences(arr, target) {

}

/*
15、题目描述
判断 val1 和 val2 是否完全等同

function identity(val1, val2) {

}
*/
function identity(val1, val2) {
    if (val1 === val2) {
        return 0;
    }
    else {
        return -1;
    }
}
console.log(identity(12, 11));


/*
16、题目描述
定义一个计算圆面积的函数area_of_circle()，它有两个参数：

r: 表示圆的半径；
pi: 表示π的值，如果不传，则默认3.14

function area_of_circle(r, pi) {

}
*/
function area_of_circle(r, pi) {
    let p = pi || 3.14;
    console.log(`圆的面积为：${p * r * r}`);
}
area_of_circle(2);

/*
17、题目描述

<!-- HTML结构 -->
<ul id="test-list">
    <li>JavaScript</li>
    <li>Swift</li>
    <li>HTML</li>
    <li>ANSI C</li>
    <li>CSS</li>
    <li>DirectX</li>
</ul>

针对以上文档结构，请把与Web开发技术不相关的节点删掉：

注意！！请分别使用原生JS和jQuery两种试实现！！！！！

*/
//js方法
var rest = document.getElementById('test-list') //取到节点
var remove = rest.removeChild(rest.children[1]);  //删除下标为1的元素
var rem = rest.removeChild(rest.children[2]);  //元素更新，删掉下标为2的元素
var remo = rest.removeChild(rest.children[3]); //元素更新，删掉下标为3的元素

// //jQuery方法 ❌
// var li = $('#test-list'); //拿到节点
// var lis = $(lis.removeChild(lis.children[1])); //删除下标为1的元素
// var list = $(list.removeChild(list.children[2])); //元素更新，删掉下标为2的元素
// var list1 = $(list1.removeChild(list1.children[3]));  //元素更新，删掉下标为3的元素

/*
18、题目描述

对如下的Form表单：

<!-- HTML结构 -->
<form id="test-form" action="test">
    <legend>请选择想要学习的编程语言：</legend>
    <fieldset>
        <p><label class="selectAll"><input type="checkbox"> <span class="selectAll">全选</span><span class="deselectAll">全不选</span></label> <a href="#0" class="invertSelect">反选</a></p>
        <p><label><input type="checkbox" name="lang" value="javascript"> JavaScript</label></p>
        <p><label><input type="checkbox" name="lang" value="python"> Python</label></p>
        <p><label><input type="checkbox" name="lang" value="ruby"> Ruby</label></p>
        <p><label><input type="checkbox" name="lang" value="haskell"> Haskell</label></p>
        <p><label><input type="checkbox" name="lang" value="scheme"> Scheme</label></p>
		<p><button type="submit">Submit</button></p>
    </fieldset>
</form>

要求:
绑定合适的事件处理函数，实现以下逻辑：

当用户勾上“全选”时，自动选中所有语言，并把“全选”变成“全不选”；

当用户去掉“全不选”时，自动不选中所有语言；

当用户点击“反选”时，自动把所有语言状态反转（选中的变为未选，未选的变为选中）；

当用户把所有语言都手动勾上时，“全选”被自动勾上，并变为“全不选”；

当用户手动去掉选中至少一种语言时，“全不选”自动被去掉选中，并变为“全选”。
*/
var
    form = $('#test-form'),
    langs = form.find('[name=lang]'),
    selectAll = form.find('label.selectAll :checkbox'),
    selectAllLabel = form.find('label.selectAll span.selectAll'),
    deselectAllLabel = form.find('label.selectAll span.deselectAll'),
    invertSelect = form.find('a.invertSelect');

// 重置初始化状态:
form.find('*').show().off();
form.find(':checkbox').prop('checked', false).off();
deselectAllLabel.hide();
// 拦截form提交事件:
form.off().submit(function (e) {
    e.preventDefault();
    alert(form.serialize());
});
// TODO:绑定事件
// 1. 当用户勾上“全选”时，自动选中所有语言，并把“全选”变成“全不选”
// 2. 当用户去掉“全不选”时，自动不选中所有语言
// 获取全选、全不选勾选框的状态
selectAll.change(function () {
    // 如果是已勾选
    if (this.checked) {
        // 选中所有语言
        langs.prop('checked', true);
        // 将“全选”隐藏
        selectAllLabel.hide();
        // 将“全不选”显示
        deselectAllLabel.show();
    } else {
        // 取消选中所有语言
        langs.prop('checked', false);
        // 将“全选”显示
        selectAllLabel.show();
        // 将“全不选”隐藏
        deselectAllLabel.hide();
    }
});
// 3. 当用户点击“反选”时，自动把所有语言状态反转（选中的变为未选，未选的变为选中）
invertSelect.click(function () {
    // 遍历所有语言
    langs.each(function () {
        // 判断是否是选中状态，如果是选中状态
        if (this.checked) {
            // 将选中的状态改为未选中
            $(this).prop('checked', false);
        } else {
            // 将未选中的改为选中
            $(this).prop('checked', true);
        }
    });
});
if (selectAll.checked = true) {
    selectAll.prop('checked', false);
    selectAllLabel.show();
    selectAllLabel.hide();
}
if (langs.not(':checked').length === 5) {
    selectAll.prop('checked', true);
    selectAllLabel.hide();
    selectAllLabel.show();
}
langs.each(function () {
    if (this.checked) {
        $(this).prop('checked', false);
    }
    else {
        $(this).prop('checked', true);
    }
});
// 4. 当用户把所有语言都手动勾上时，“全选”被自动勾上，并变为“全不选”
// 5. 当用户手动去掉选中至少一种语言时，“全不选”自动被去掉选中，并变为“全选”
// 获取所有语言的总个数
var long = langs.length;
// 设置初始勾选了0个
var count = 0;
// 点击勾选框
langs.click(function () {
    count = 0;
    // 遍历每一个语言
    langs.each(function () {
        // 如果勾选上了
        if (this.checked) {
            // 勾选个数自增
            count++;
        }
    });
    // 如果总个数等于勾选的个数
    if (long == count) {
        // 将全选框勾选上
        selectAll.prop('checked', true);
        // “全选”隐藏
        selectAllLabel.hide();
        // “全不选”显示
        deselectAllLabel.show();
    } else {
        // 全选框取消勾引
        selectAll.prop('checked', false);
        // “全选”显示
        selectAllLabel.show();
        // “全不选”隐藏
        deselectAllLabel.hide();
    }
});

// 测试:
console.log('请测试功能是否正常。');
